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(54) Wireless communication protocol for printing 



(57) A wireless communication protocol for print by 
reference operations initiated by a portable wireless de- 
vice allows a portable wireless device, such as a hand- 
held personal digital assistant, to initiate a print job with 
a printer by indicating the nature of the communication 
as a print by reference operation and identifying a loca- 
tion including print content. The protocol is preferably 
used as the body of an Object Exchange (OBEX) packet 



in a Bluetooth RF communication initiated by the porta- 
ble wireless device with a Bluetooth capable print de- 
vice, e.g., a printer or multi-function peripheral with a 
print capability. A preferred embodiment of the wireless 
communication protocol uses the body of an OBEX 
packet communicated by Bluetooth RF to include a tag 
identifying a packet body as being a packet body for a 
print by reference operation and a location identifying 
the location of the print content. 
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Description 

[0001] The present invention relates to wireless device communication protocols, and to printing. In particular it 
relates to a portable wireless device and print device print by reference protocol. 

5 [0002] Portable wireless devices such as personal digital assistant (PDA) devices and portable wireless handsets, 
e.g., cell phones, enjoy widespread popularity. The popularity of these devices invites attempt to expand their uses. 
The introduction of Internet browsing in PDA devices and wireless handset devices is an excellent example of the effort 
to expand the device uses. As device uses increase, commercial service opportunities increase. The introduction of 
Internet capabilities into the portable wireless devices permits the sale of wireless access. 

10 [0003] The limited memory, display, and bandwidth capabilities of portable wireless devices limits commercial op- 
portunities by restricting the type of content readily available to a wireless device user. Content is typically formatted 
specifically for a wireless device in away to conserve device capabilities. Rich content is avoided in favor of bare bones 
content. Users will accordingly favor more traditional connections through personal computers and work stations unless 
circumstances such as travel prevent access to such computers. In many ways, the PDA devices and wireless handsets 

15 remain a content access method to be used for highly basic content or to access content only when circumstances 
prevent a user from accessing content from another device. 

[0004] Printing offers the opportunity for a user to view rich content, and is often favored over viewing content through 
a full web browser or other application on a personal computer or work station. In contrast the wireless devices with 
limited capabilities lack convenient printing mechanisms. Operations to connect the devices via a wired connection 

20 almost defeat the purpose of having a portable wireless device in the first place. 

[0005] One answer to these concerns is found in efforts to have the portable wireless devices communicate with 
peripherals and other devices through wireless communications. The Bluetooth RF communication format, for example, 
is directed toward expanding the utility of portable wireless devices by providing a short range, typically about 10 
meters, communication channel for communications between portable wireless devices and other Bluetooth capable 

25 devices. Standing alone, the communication channel offers little to solve the print content dilemma faced by users of 
portable wireless devices, though. Due to the memory and bandwidth limitations portable wireless devices are relatively 
poor portals to push content from or through to a printer, even with the convenience of a Bluetooth or other similar 
wireless communication capability 

[0006] Wireless print by reference allows a portable device to conveniently access print content by a wireless com- 
30 munication with a print device communicating a referenced print content to the print device, which then accesses and 
prints the print content. In a typical preferred example, the portable wireless device might obtain a reference to a print 
content, e.g., a Universal Resource Locator, while performing an operation such as web browsing over a wireless 
network. The present invention provides a protocol that allows a portable wireless device, such as a handheld personal 
digital assistant, to initiate a print job with a printer by indicating the nature of the communication as a print by reference 
35 operation and identifying a location including print content. The protocol is preferably used as the body of a Generic 
Object Exchange (OBEX) packet in a Bluetooth RF communication initiated by the portable wireless device with a 
Bluetooth capable print device, e.g., a printer or multi-function peripheral with a print capability. A preferred embodiment 
of the wireless communication protocol uses the body of an OBEX packet communicated by Bluetooth RF to include 
a tag identifying a packet body as being a packet body for a print by reference operation and a location identifying the 
-*o location of the print content. With a preferred extensible mark-up language format, the location comprises an attribute. 
Additional attributes may, for example, include attributes enabling security clearance, billing identifications, use of sup- 
porting print services, and identification of alternate locations for targeted print content. 

FIG. 1 is a communication flow diagram indicating a simple print by reference communication exchange in accord- 
•*5 ance with a preferred embodiment of the present invention; 

FIG. 2a illustrates a preferred OBEX simple reference packet structure for a preferred embodiment of the present 
protocol; 

FIG. 2b illustrates a preferred OBEX XML reference packet structure for a preferred embodiment of the present 
protocol; and 

so FIG. 3 illustrates a preferred environment and usage model for a protocol of the invention. 

[0007] A simple form of the invention is a protocol permitting, as a minimum, identification of a communication by a 
portable wireless device as relating to a print by reference operation and an indication of the location of the print content 
to be printed. An identification tag and a Universal Resource Locator meet these minimum requirements. A preferred 
55 embodiment relies upon a Bluetooth wireless communication and embeds the minimum protocol requirements in the 
body of a Generic Object Exchange (OBEX) packet body. Some portable wireless devices will find this level of protocol 
sufficient, while print devices and other portable wireless devices are more likely to benefit from an embodiment of the 
present protocol that allows for the communication of additional information concerning the print job, or features and 
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services relating to the print job. The preferred embodiment protocol discussed and illustrated herein accounts for 
potential enhanced print by reference jobs, and features and services relating to print jobs to afford enhanced usability 
and commercial prospects by use of the present protocol. Artisans will appreciate, though, that the protocol in its simple 
form offers the ability .for a print by reference to be initiated successfully by a portable wireless device with a simple 
5 identification of the print by reference nature of the communication and an identification of the location of the print 
content to be printed. 

[0008] Bluetooth is a preferred wireless RF standard developed by a technology industry consortium made up of 
3Com, Ericsson, IBM, Intel, Agere, Microsoft, Motorola, Nokia, and Toshiba with a mission of creating a standard 
wireless protocol. More information, including protocol specifications, can be obtained on the Bluetooth website: www. 
10 bluetooth.com, with the content available from this and linked websites incorporated herein by reference. The current 
Bluetooth protocol has an operable range of about 10 meters, but may sometimes prove to have greater range. As an 
example software/device for the underlying Bluetooth communication protocol, a Bluetooth PC card was unveiled by 
3Com on May 29, 2001. The card follows the new Bluetooth 1 .1 specification and uses 3CorrVs connection manager 
software. 

15 [0009] Other example communication protocols suitable for practice within the scope of the invention that have avail- 
able commercial support are those specified by IEEE 802.11 standard. 100 meters is the optimal 802.11 maximum 
range, but 802.1 1 can work at around 300 meters. However the data rate goes from 11 Mega bits per second to about 
1 or 2 Mega bits per second as range increases. Bluetooth power class III is designed for 10 meters at low power. 
Bluetooth Power class I uses 100 milliwatts and can go about 100 meters. Artisans will also appreciate that wireless 

20 protocols other than 802.1 1 and Bluetooth, e.g., infrared, might also be used and that certain preferred features, e.g., 
an OBEX connect are therefore unique to the preferred Bluetooth embodiment since the Bluetooth protocol requires 
a CONNECT while OBEX does not. 

[0010] FIG. 1 shows a communication exchange adopting a preferred embodiment of the present protocol. In FIG. 
1, a portable wireless device 10 initiates a wireless communication with a print device 12, which may be a printer or 

25 multi-function peripheral including a print function. The wireless communication occurs over a wireless communication 
channel. This is a Bluetooth wireless communication in the preferred embodiment of FIG. 1 , and uses the OBEX packet 
exchange. The portable wireless device 1 0 establishes a connection with the printer via the OBEX conventions. Once 
the OBEX connection is established, via an OBEX connect and response exchange, the portable device 10 uses the 
body of an OBEX packet to conduct a simple reference push to the print device 12. The minimum information in the 

30 packet body must identify the communication as concerning a print by reference operation, and must indicate the 
location of the print content to be printed. The print device 12 may respond with an acknowledgment. 
[0011] FIG. 2a shows an exemplary OBEX packet 14 including the minimum protocol information of a preferred 
embodiment protocol. The preferred embodiment protocol uses a tag 16 identifying the packet information as print by 
reference information and a Universal Resource Locator (URL) 18 identifying the location of content to be printed. A 

35 standard OBEX packet header 20 precedes the body 22 including the tag 16 and the URL 1 8. The nature of content 
to be printed as a result of this communication is essentially unlimited by the remaining capabilities of the portable 
wireless device 10. 

[0012] A further preferred embodiment of the invention provides for enhanced control over the print by reference 
operation and the opportunity to tie in useful commercial features such as those relating to billing the user of a portable 

40 wireless device 10 as part of a print by reference operation or ensuring secure access to print content available for 
print by reference operations. Use of an extensible markup language (XML) format for the print by reference packet 
body, as shown in FIG. 2b using the reference numbers assigned in FIG. 2a : permits the inclusion of Meta information 
to be passed from the portable wireless device along with the Universal Resource Locator. The preferred XML print 
by reference packet body is an XML tag having the following syntax: 

45 <reference url="scheme://host/resourcepath" 

attrl ="attr1 val" attr2="attr2val". . . 
attnWatlrnvar \> 

The "reference" is an XML tag and, in the above example, indicates a simple print by reference communication for 
printing content from a location identified by the "url" attribute following the "reference" tag. An identification of the 
50 location of the print content meets the minimum requirement, and additional attributes "attrl" - "attrn" may follow for 
enhanced print by reference operations. Al. of the attributes are optional except for the URL that must be included and 
be fully qualified. Table 1 defines a set of attributes used in a preferred embodiment protocol of the invention: 



Attribute 
Name 


Comment 


label 


Descriptive name of the resource referred to by the reference, (e.g. label="Sales Document") 
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(continued) 





Attribute 
Name 


Comment 


5 


url 


Fully qualified Uniform Resource Locator (RFC 1738) 


7 U 


use_proxy 


Fully qualified URL that represents an HTTP proxy service that must be used to access the 
content referred to by the reference. The Port for the proxy shall be specified in the URL if not 
port 80 

(e.g. use proxy="http://corp proxy:8088") 




use_service 


Fully qualified URL that represents the location of a remote print service that shall be used to 

process the reference. 

(e.g. use_service= ,, http://myprintsvc:456") 


15 


ip_addr 


Internet Address of the sender (portable wireless device). Provides hint to the receiver (print 
device) that sender (portable wireless device) is an internet device. Examples: 
ip_addr= u 1 26.34.07.6" 
ip_addr="::126.34.07.6" 
ip_addr="FC01 :0:0:0:0:0:0:23" 


20 


type tvoe 


Encoding of the resource referred to by the reference, (e.g type="text/html") 


25 


cookie 


Cookie that can be used by the receiver (print device) when processing the reference. This 
attribute uses the general form of the HTTP Cookie Mime header NAME1=OPAQUEVALUE; I 
NAM E2=OPAQUE VALUE 

(e.g. cookie^" CUSTOMER=WILE_E_COYOTE; 
PART_NUMBER=ROCKET_LAUNCHER_0001 ") 


30 


on401 


Provides the receiver (print device) with information that can be used when an HTTP 401 security 
challenge is encountered while processing the reference. The format of this attribute is that of 
the HTTP 




Authorizalion header defined in R FC261 7. For example a credential that uses the "Basic" security 
scheme with the user id Aladdin and password "open sesame" would be encoded as follows: 
on401="Basic 

QWxhZGRpbjpvcGVulHN1c2FtZQ==" 


35 


on407 


Same as on401 except used in response to a HTTP 407 proxy challenge. The format is the same 
as on401 


40 


time 


Used to signify the time the reference was sent to the Printer. 

Time is a byte sequence that gives the object's UTC date/time of last modification in ISO 8601 
format. Local times should be represented in the format YYYYMMDDTHHMMSS and UTC time 
in the format YYYYMMDDTHHMMSSZ. The letter "T" delimits the date from the time. UTC time 
is identified by concatenating a "Z" to the end of the seq uence. When possible UTC times should 
be used. 


45 


key 


The key attribute is an optional attribute that can be used to associate security information with 
the reference. This can be used when challenged for security information. In general such keys 
should be encrypted and time sensitive to prevent arbitrary delegation from compromising 
security. The format of this attribute conforms to the Authorization field in RFC261 7 and contains 
both the security scheme and the encrypted key. This format is the same as on401 


50 


on[status code] 


This status code allows the sender (portable wireless device) to provide the receiver (print device) 
with an alternative URL to process in the event of a particular HTTP status code e.g. 
on400="http://www.bluelooth.org" 

The URL specified would be used in the event of a HTTP 400 status code 


55 


billing 


This code allows for billing services. As an example, a personal wireless device can provide a 
billing reference number to access print content requiring payment of a fee. The billing code might 
also be used for other fee based transactions, e.g. payment for use of a public access printer 
with print by reference capabilities or payment for use of a print service identified by the 
"use_service" attribute. 
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(continued) 



Attribute 
Name 


Comment 


new_sheet 


This Boolean attribute indicates to a print device or print service that a referenced print content 
should be printed beginning on a new sheet of media. 



[0013] The "url" attribute is a location attribute identifying the location of the print content. The portable wireless 
10 device 10 provides the "url" attribute, e.g., " http://www.bluetooth.org " to identify the location of targeted print content 
to the print device 12. A fully qualified URL is preferred, though the print device 12 may be set up to resolve less 
complete URL designations in a manner similar to web browsers. In a contemplated use of the invention, the portable 
wireless device 1 0 obtains the URL for a print by reference by clicking on a "print" link while web browsing or reviewing 
other content including links. 

15 [001 4] The "label" attribute is a description attribute providing a name for the location identified by the "url" attribute. 
This may be a descriptive name of the resource to provide the content to be printed, for example. The descriptive name 
could be useful to provide track print operations, by any device associated or involved with the print by reference 
operation initiated by the portable wireless device. 

[0015] In the preferred embodiment detailed in Table 1 , the "use_proxy" attribute is a fully qualified URL that repre- 
20 sents an HTTP proxy service that must be used to access the content referred to by the reference. The Port for the 
proxy is specified in the URL if it is not a default port, e.g., port 80. Ports are used in the TCP to name the ends of 
logical connections which carry long term conversations. For the purpose of providing services to unknown callers, a 
service contact port is defined. The contact port is sometimes called the "well-known port". Port number 80 is the well 
known port number for HTTP and the world wide web. See, e.g., http://www.iana.org/assignments/port-numbers. 
25 [0016] Content accessed by a print by reference operation may not be in printer device format. "use_service" is an 
attribute identifying a location of a print service to be used in accessing the print content. The print service retrieves 
the content and formats the data in a format that the printer is able to print. 

[0017] A print device 12 equipped with print by reference capabilities may have a reason to recognize portable wire- 
less devices. The "ip_address" facilitates such recognition by identifying a wireless device Internet address. The 

30 "ip__address" thus provides an indication to the print device 12 receiving a wireless communication from the portable 
wireless device 12 with the print by reference protocol that the portable wireless device is an Internet device. 
[0018] Access to a referenced print content location may be limited by any number of means to restrict access down 
from a level of universal public access. The preferred embodiment protocol of Table 1 provides a number of attributes 
to facilitate different access levels useful to assist in processing the print content as part of a print by reference operation. 

35 The "type" attribute is an encoding type attribute indicating how the print content at the location identified by the location 
attribute is encoded. For example, type=html or type=pdf respectively indicate html and pdf encoded content. The 
"cookie" attribute can associate a print by reference job with previous information concerning reference content or 
portable wireless device seeking to access referenced content. Thus, the cookie attribute identifying a cookie usable 
to process the print content at the location identified by the location attribute. Preferably, the cookie attribute uses a 

40 cookie name formatted according to HTTP Cookie MIME header name conventions. 

[0019] Security is another type of access control. "on401" and '^407" are separate security attributes identifying 
security information that can be used in response to a security challenge. Attribute "on401 " is security information that 
can be used in response to an HTTP 401 security challenge. Attribute "on407" is security information that can be used 
in response to an HTTP 407 proxy challenge. Preferably, the format of each of the HTTP 401 and HTTP 407 security 

45 attributes is in accordance with the HTTP Authorization header of RFC2617. RFC indicates an Internet standards- 
related specification published as part of the "Requests for Comments" (RFC) document series. The archival series is 
the official publication channel for Internet standards documents and other publications of the Internet community. 
RFCs can be obtained from a number of Internet hosts using anonymous gopher, World Wide Web, and other Internet 
document-retrieval systems. RFCs are published by the Internet Engineering Task Force (IETF), which is a large open 

50 international community of network designers, operators, vendors, and researchers concerned with the evolution of 
the Internet architecture and smooth operation of the Internet. RFCs are published by the IETF, see, e.g., http://www. 
ietf.org/rfc/html. 

[0020] Time is useful in various security encoding or other operations. For example, time stamps are often used to 
authenticate communications. The "time" attribute indicates the time at which a packet is sent by the wireless device 
55 to initiate a print of print content. The preferred "time" attribute gives the wireless device's Universal Time Code date 
and time of last modification in ISO 8601 format. The "key" attribute associates security information with the reference 
tag, and is preferably an encrypted and time-sensitive key 

[0021] A print by reference operation may be impeded by a print content location that is experiencing difficulties or 
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refuses to complete a print by reference operation. In that case, the print by reference might proceed through an 
alternative location including the same or substitute content. The "status code" attribute indicates an alternative location 
to obtain such alternative print content. 

[0022] Revenue generation may arise at different points of a print by reference operation . Examples include schemes 

5 where portable wireless device users pay for access to content or pay for access to print by reference printers. Many 
other commercial models are possible, with the print by reference being tied to a direct payment or stemming from a 
related commercial or promotional transaction. Various debit and credit models of payment are facilitated by the "billing" 
attribute that identifies one of the wireless device 1 0 or user of the wireless device for billing purposes. 
[0023] The "new_sheet" attribute is preferably a Boolean attribute that indicates to a print device or print service that 

w a referenced print content should be printed beginning on a new sheet of media. As an example, new_sheet="false" 
indicates that a referenced print content, e.g. a document, should not start on a new sheet. This again, like all attributes 
excepting a reference to target print content, is a preferred option. A print device or print service handling a print by 
reference request from a portable wireless device 10 may have default settings for any one of the preferred set of 
optional attributes or other optional attributes that may be supported by a particular print device or print service. In the 

15 case of the "new_sheet" attribute, a preferred default setting is new_sheet="true". 

[0024] The discussed examples generally assume a simple and single print by reference operation to print single 
content from a specific location. The attributes add features and Meta information to enhance or assist printing from 
a specific location. While a single reference print may be indicated by the "reference" tag, additional types of print by 
reference operations can be supported by having separate tags, e.g. "referencel" "reference2", etc. A preferred ex- 

20 ample is a tag to indicate that attributes will follow for multiple print content references, i.e., a reference list. Another 
preferred option is to use the packet header to indicate the type of print by reference packet body that will follow. 
Exemplary preferred OBEX header values for three different types of print by reference operations are defined in Table 
2: 



Type Header Value 


Description 


text/x-ref-simple 


Simple Reference 


text/x-ref-xml 


XML Reference 


text/x-ref-list 


Reference List 



In FIG. 2a, for example, the OBEX packet header 20 indicates the body 22 contains a simple reference for printing by 
reference. With a reference list, a single or multiple packets might include additional references to be processed, each 
of which may be a simple reference but is preferably an XML reference as in the example of FIG. 2b. 
[0025] FIG. 3 shows a preferred environment and usage model in which the protocol of the invention may be used. 
A print device 12 accesses a print service, either via the Internet to a web site print service 24, or through another 
connection to a local print service 26 that may comprise software in the print device 12 when the print device 12 is 
carrying out a print-by-reference operation initiated by a portable wireless device 1 0 that connects to the print device 
12 via a wireless protocol and the print by reference protocol of the invention. While the local print service 26 is shown 
as an external device to the print device 12, it may also be internal to the print device 12. For example, it may be native 
software or an add on software. It might also be installed as a firmware card. 

[0026] In a preferred use, the print device 12 accepts a print by reference communication from the portable wireless 
device 10 and uses the print service 24 or 26 to resolve and access the content to be printed. The print service 24 or 
26 executes a method that accepts, from a print client, a reference to print content targeted for printing from a location 
indicated by the reference. The reference is resolved to determine the location indicated by the reference. Print data 
is obtained from that location and transcoded into a printer ready format. The print client is allowed to access to print 
ready formatted data, which may be transferred to the print client in response to a request from the print client. 
[0027] A likely scenario involves the portable wireless device 1 0 accessing a content provider 28, typically a web 
site over the Internet, via, for example via a cellular wireless web protocol 29. The web site might include a link to print 
content, such as a "print-this" link. If selected, the print by reference target is transmitted to the portable wireless device 
10 via web protocol 29, which then can commence a print by reference operation with the print device 12. In the 
preferred environment of FIG. 3, the portable wireless device 10 uses Bluetooth wireless 30 to communicate a print 
by reference target to the print device 12 by the protocol of the invention. 

[0028] After receiving a print by reference communication, the print device 1 2 then accesses the print service 24 via 
an Internet interface 30. However, the protocol might also be used in communications between other devices. For 
example, the portable wireless device 1 0 may use the protocol to initiate print by reference directly with one of the print 
service 24 or 26. 

[0029] A number of paths for passing a print reference by the protocol of the invention are therefore possible. The 



6 



BNSDOCID: <EP 1271889A2J_> 



10 



EP 1 271 889 A2 

protocol might also find use in other environments to target content for printing. Underlying communication protocols, 
e.g., Bluetooth, and wireless media may vary in applications of the invention. Artisans will appreciate that the simple 
reference communications and meta tag communication formats may be altered as necessary to suit a desired com- 
munication protocol or wireless media. 

[0030] Thus, while various embodiments of the present invention have been shown and described, it should be 
understood that other modifications, substitutions and alternatives are apparent to one of ordinary skill in the art. Such 
modifications, substitutions and alternatives can be made without departing from the scope of the invention, which 
should be determined from the appended claims. 

[0031] Various features of the invention are set forth in the appended claims. 
Claims 

1. A wireless communication protocol for use by a wireless device and a print device for a wireless device to initiate 
'5 a print by reference operation with the print device, the protocol comprising content for the body of a packet (14) 

and including: 

a tag (16) identifying a packet body (22) as being a packet body for a print by reference operation for the 
wireless device to initiate a print of print content; and 
20 a location attribute identifying the location of the print content. 

2. The protocol according to claim 1 , wherein said location attribute requires a uniform resource locator identifying 
the location of the print content. 

25 3. The protocol according to claim 1 , wherein the content for the body of the packet further comprises a description 
attribute providing a name for the location identified by the location attribute. 

4. The protocol according to claim 1 , wherein the content for the body of the packet further comprises a print service 
attribute identifying a location of a print service to be used in accessing the print content. 

30 

5. The protocol according to claim 1 , wherein the content for the body of the packet further comprises a device address 
attribute identifying an Internet address of the wireless device. 

6. The protocol according to claim 1 , wherein the content for the body of the packet further comprises an encoding 
35 type attribute indicating how the print content at the location identified by the location attribute is encoded. 

7. The protocol according to claim 1 , wherein the content for the body of the packet further comprises a cookie 
attribute identifying a cookie usable to process the print content at the location identified by the location attribute. 

40 8. The protocol according to claim 1 , wherein the content for the body of the packet further comprises a billing attribute 
identifying one of the wireless device and a user of the wireless device for billing purposes. 

9. A wireless communication protocol for use by a wireless device and a print device for a wireless device to initiate 
a print by reference operation with the print device, the protocol comprising elements for: 

45 

establishing the nature of the communication as relating to a print by reference operation; and 
providing a reference identifying a location of content to be printed. 

10. The wireless communication protocol according to claim 9, wherein the reference comprises a Universal Resource 
50 Locator. 
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